草庐IT

TypeScript 运算符

全部标签

javascript - 当一个是 bool 值时,为什么 JavaScript 在 == 运算符比较中将原始值转换为数字的基本原理?

我知道规则:Ifthetwooperandsarenotofthesametype,JavaScriptconvertstheoperandsthenappliesstrictcomparison.Ifeitheroperandisanumberoraboolean,theoperandsareconvertedtonumbersifpossible;elseifeitheroperandisastring,theotheroperandisconvertedtoastringifpossible.所以,if("true")通过但if("true"==true)失败,因为它的句柄类似于

javascript - 我如何在 typescript 中声明一个 'monkey patched' 原型(prototype)

我正在为webgl-utils.js创建一个d.ts文件来自谷歌我对最后一行中的一个全局对象中的方法“猴子修补”有疑问(我认为这是正确的术语)问题行如下:/***ProvidesrequestAnimationFrameinacrossbrowserway.*/window.requestAnimFrame=(function(){returnwindow.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimation

javascript - Typescript 错误引用 _this

我尝试在TypeScript中为String.Prototype定义一些属性:Object.defineProperty(String.prototype,'test',{value:()=>{console.log("thisisatestovertext"+this);}})在javaScript原型(prototype)中,this指调用方法的对象(在本例中为字符串值)。但是文件的编译输出是:var_this=this;Object.defineProperty(String.prototype,'test',{value:function(){console.log("this

javascript - 在 Typescript 中,从 Typeings 导入时如何使用 Javascript 模块

使用mgechev'sangular2-seed,我正试图掌握Angular2和一个新项目的typescript,但遇到了这个问题。我想在组件中使用数字,所以我:使用npminstallnumeral安装Numeral使用typingsinstalldt~numeraljs--global--save安装了数字类型在我的组件中添加了import{numeral}from'/typings/globals/numeraljs';添加了代码行:letnum:Number=newNumber(numeral().unformat(text));到目前为止,还不错。一切似乎都可以正常进行。直到

javascript - typescript/javascript 中的递归函数

我正在尝试递归调用以下函数。publicgetData(key,value){this.htmlString+=''+key+':';if(valueinstanceofObject){Object.keys(value).forEach(function(keydata){letobj=value[keydata];this.getData(keydata,value[keydata]);console.log(key,obj,objinstanceofObject)});}else{this.htmlString+=''+value+'';}returnthis.htmlStrin

javascript - 关于何时在 TypeScript 中调用装饰器的困惑

我的印象是TypeScript中的装饰器是在类的构造函数之后调用的。但是,有人告诉我其他情况,例如,this的最佳答案post声称Decorators在声明类时被调用——而不是在实例化对象时调用。我参加的一门Angular类(class)的Udemy讲师还告诉我,Typescript中的装饰器在属性初始化之前运行。但是,我在这个主题上的实验似乎表明情况并非如此。例如,这是一段带有属性绑定(bind)的简单Angular代码:test.component.tsimport{Component,Input}from'@angular/core';@Component({selector:'

javascript - "in"运算符或 obj.hasOwnProperty(prop) 的 Big O 表示法的效率是多少

Mozilla的网站清楚地描述了hasOwnProperty()。和in运营商。但是,它没有提供有关其效率的任何实现细节。我怀疑它们会是O(1)(常数时间),但我希望看到任何可能存在的引用或测试。 最佳答案 将我的评论变成答案。hasOwnProperty()应该O(1),因为它是一个键查找,但它是特定于实现的。in肯定会更复杂(尽管应该与hasOwnProperty()相同,如果属性存在于该对象上),因为它沿着原型(prototype)链上升,寻找那个属性(property)。这就是为什么通常建议在使用for(in)遍历对象属性时

javascript - 为什么我们不能在没有 new 运算符的情况下调用 Date() 类的方法

这个问题在这里已经有了答案:DifferencebetweenDate(dateString)andnewDate(dateString)(10个答案)关闭8年前。假设我这样定义一个变量vartoday=Date();console.log(today.getMonth());//ThrowError而像Error类这样的其他类在没有new运算符的情况下调用它们的方法。functionfactorial(x){if(x包装器对象(数字、bool值、字符串)也可以在没有new运算符的情况下调用它们的方法。那么,这是唯一一个在调用它们的方法之前需要new运算符或任何对象创建技术的类吗。编辑

javascript - 如何在 TypeScript 中从匿名对象轻松创建强类型对象?

我的客户端有一些包含匿名对象的JSON。是否有一些内置机制或外部库可以将这些匿名对象转换为强类型的TypeScript对象?是否有类似AutoMapper的工具可以执行此操作?我的对象是复杂类型,以复杂类型作为属性。 最佳答案 获取一些示例数据并将其放入.ts文件中:varpeople=[{"name":"bob","height":150,"pets":[{"name":"spot","species":"dog"}]},{"name":"jane","height":142,"pets":[{"name":"lucy","spe

javascript - 我做错了什么,或者这是一个错误? ( typescript / Visual Studio 2012)

已解决:谢谢大家的帮助。我不确定到底是什么原因造成的,但我重新启动了VisualStudio,一切都恢复正常了。不知道为什么,但从(昨天)开始它就一直在工作。我昨晚没有遇到这些问题(使用相同的代码-未更改):我不明白这是什么问题。我得到的错误是:JavaScriptcriticalerroratline1,column9in[path/app.ts]SCRIPT1004:Expected';'.这是怎么回事?!万一你看不到图像,错误是指这一行:声明var文件;更新将TypeScript编译成JavaScript的javascript文件如下所示:window.onload=functi